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- The MAILING DATE of this communication appears on the cover sheet with the correspondence address - 
Period for Reply 

A SHORTENED STATUTORY PERIOD FOR REPLY IS SET TO EXPIRE 3 MONTH(S) FROM 
THE MAILING DATE OF THIS COMMUNICATION. 

- Extensions of time may be available under the provisions of 37 CFR 1.136(a). In no event, however, may a reply be timely filed 
after SIX (6) MONTHS from the mailing date of this communication. 
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• Failure to reply within the set or extended period for reply will, by statute, cause the application to become ABANDONED (35 U.S.C. § 133). 
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2a)D This action is FINAL. 2b)[3 This action is non-final. 
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4) M Claim(s) 7-30 is/are pending in the application. 
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5) D Claim(s) is/are allowed. 

6) S Claim(s) 1-30 is/are rejected. 
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9) D The specification is objected to by the Examiner. 
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DETAILED ACTION 



Claim Objections 



1 . Claims 21, 28, and 30 are objected to because of the following informalities: 

The claims are objected to because they include reference characters that are not enclosed 

within parentheses; eg, in claims 21, 28, and 30 the reference to "design surface module [402]" 

should read, "design surface module (402}." 

Reference characters corresponding to elements recited in the detailed description of the 

drawings and used in conjunction with the recitation of the same element or group of elements in 

the claims should be enclosed within parentheses so as to avoid confusion with other numbers or 

characters which may appear in the claims. See MPEP § 608.01(m). 

Appropriate correction is required. 



2. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set forth in 
section 102 of this title, if the differences between the subject matter sought to be patented and the prior art are 
such that the subject matter as a whole would have been obvious at the time the invention was made to a person 
having ordinary skill in the art to which said subject matter pertains. Patentability shall not be negatived by the 
manner in which the invention was made. 



DETAILED ACTION 



Claim Rejections - 35 USC §103 
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3. Claims 1 - 6, 7 - 12, and 13 - 18 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Fowlow et al., U.S. Patent 6,189,138 (hereinafter referred to as Fowlow) in 
view of Goldberg et al, U.S. Patent 6,571,232 (hereinafter referred to as Goldberg). 

In regard to claim 1: 

"dragging a graphical representation for a server processing resource from a server 
explorer module to a visual design surface module to add a processing item to a programmable 
data object being created in the visual design surface module; " Fowlow discloses a drag and 
drop function wherein a component representing software resources on a distributed object 
system (column 9, lines 45 - 47) is selected and dragged from one panel and dropped onto 
another panel being a worksheet (visual design surface) where the object component is 
manipulated in an application construction (column 1 1, lines 29 - 46). 

"identifying data schema associated with the server processing resource added to the 
programmable data object; " Fowlow discloses a drag and drop function that allows a user to 
configure objects in a visual design surface giving the developer detailed information about the 
objects (column 12, lines 20 - 24), but does not specifically disclose identification of a data 
schema associated with a resource. However, Goldberg discloses identification of a database 
schema associated with a server resource (column 2, lines 9 - 37; e.g., Figure 3). Therefore, it 
would have been obvious to one skilled in the art at the time the invention was made to combine 
the drag and drop feature for building applications in the Fowlow invention with the 
identification of a database schema in the Goldberg invention because the Fowlow invention 
discloses that detailed information about a resource is available to the developer (column 9, lines 
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54-55) in the worksheet (a visual design surface), and one skilled in the art would logically 
include a data schema if a database resource was selected in a tiered distributed object system as 
taught by Goldberg (column 2, lines 17 - 37). 

"creating a typed dataset containing the data structures corresponding to the data 
schema associated with the server processing resource; " Fowlow discloses a drag and drop 
function that allows a user to configure objects in a visual design surface giving the developer 
detailed information about the objects, but does not disclose a dataset containing data structures 
corresponding to the resource schema. However, Goldberg discloses generation of query objects 
based on a schema of an underlying database (column 2, lines 15-31; column 3, lines 13-19). 
Therefore, it would have been obvious to one skilled in the art at the time the invention was 
made to combine the drag and drop function allowing a user to configure objects in a visual 
design surface giving the developer detailed information about the objects in the Fowlow 
invention with the generation of query objects based on a schema on an underlying database in 
the Goldberg invention because the Fowlow invention discloses that detailed information about a 
resource is available to the developer (column 9, lines 54 - 55) in the worksheet (a visual design 
surface), and one skilled in the art would logically include a data schema if a database resource 
was selected in a tiered distributed object system as taught by Goldberg (Abstract; column 2, 
lines 17 -37). 

"creating a command adapter to provide data transfer commands within the 
programmable data object between the programmable data object and the server processing 
resource; " Fowlow discloses that a distributed object system typically includes an object 
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request broker to provide transport mechanisms for communications between a client and a 
server (column 14, lines 24 - 58; e.g. Figure 10). 

"creating a data transfer connection between the programmable data object and the 
server processing resource. " Fowlow discloses that a distributed object system typically 
includes an object request broker to provide transport mechanisms for communications between 
a client and a server (column 6, lines 16 - 21 and 30 - 37). 

In regard to claim 2, incorporating the rejection of claim 1 : 

".. creating additional initialization methods to support the items added to the 
programmable data object " See Fowlow, column 11, lines 20 - 46. 

In regard to claim 3, incorporating the rejection of claim 2: 

"... editing the processing items within the visual design surface module, See Fowlow 
column 4, lines 1 8 - 26. 

updating the processing items edited within visual design surface module; See Fowlow 

column 4, lines 35-43. 

updating the typed dataset within visual design surface module, See Fowlow column 4, 

lines 26 - 34. 

updating the command adapters within the visual design surface module, See Fowlow 
column 4, lines 26 - 34. 

identifying any other processing items containing references to data structures and 
functions edited, See Fowlow column 4, lines 26 - 34. 

updating the identified items containing references to data structures and functions 
edited to make all references consistent with each other." See Fowlow column 4, lines 26 - 34. 
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In regard to claim 4, incorporating the rejection of claim 3: 
"..the items comprise properties and processing instruction source code that may be 
edited. " See Fowlow column 4, lines 35 -43. 

In regard to claim 5, incorporating the rejection of claim 1 : 
" ...inserting a database connection module that creates a data transfer connection 
between the programmable data object and a database when the dragged item is database table 
within the database. " Fowlow teaches a means to insert connections among modules, but does 
not specifically teach that the dragged item is a database table. However, Goldberg teaches 
query objects of schemas including database tables (column 3, lines 37 - 54). Therefore, it 
would have been obvious to one skilled in the art at the time the invention was made to combine 
the insertion of connections among modules in a visual design surface as taught by Fowlow with 
the generation of query objects based on a schema on an underlying database, including tables in 
the Goldberg invention, because one skilled in the art would be motivated to include all relevant 
features of the database that require generation of code for an interface of a query object as 
taught by Goldberg (Abstract) in a visual tool designed to construct object-oriented applications 
as taught by Fowlow. 

In regard to claim 6, incorporating the rejection of claim 5: 
"a data connection object for creating and managing the data transfer connection 
between the programmable data object and the database; Fowlow teaches implementation of 
relationships among objects when the application is run (Abstract; column 4, lines 45 - 60) 

a managed resource module for provides the data connection object with address and 
identification information to establish that data transfer connection; Fowlow discloses that a 




Application/Control Number: 09/734,072 Page 7 

Art Unit: 2124 

distributed object system typically includes an object request broker to provide transport 
mechanisms for communications between a client and a server (column 6, lines 16-21 and 30 - 
37). 

a persistent data storage for maintaining this address and identification information used 
by the managed resource module, " See Fowlow Figure 1 . 

In regard to claim 7: 

Claim 7 (a system claim) is rejected for the same reasons put forth in the rejection of 
claim 1 (a corresponding method claim) with the following differences also found in the Fowlow 
reference: 

"a memory module; (Figure 3) 

a user interface module; (Figure 4) 

a mass storage system; (Figure 1) 

In regard to claim 8, incorporating the rejection of claim 7: 

Claim 8 (a system claim) is rejected for the same reasons put forth in the rejection of 
claim 2 (a corresponding method claim). 

In regard to claim 9, incorporating the rejection of claim 8: 

Claim 9 (a system claim) is rejected for the same reasons put forth in the rejection of 
claim 3 (a corresponding method claim). 

In regard to claim 10, incorporating the rejection of claim 9: 

Claim 10 (a system claim) is rejected for the same reasons put forth in the rejection of 
claim 4 (a corresponding method claim). 
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In regard to claim 11, incorporating the rejection of claim 10: 

Claim 1 1 (a system claim) is rejected for the same reasons put forth in the rejection of 

claim 5 (a corresponding method claim). 

In regard to claim 12, incorporating the rejection of claim 11: 

Claim 12 (a system claim) is rejected for the same reasons put forth in the rejection of 

claim 6 (a corresponding method claim). 



In regard to claim 13: 

Claim 13 (a computer program product claim) is rejected for the same reasons put forth 
in the rejection of claim 1 (a corresponding method claim). 

In regard to claim 14, incorporating the rejection of claim 13: 

Claim 14 (a computer program product claim) is rejected for the same reasons put forth 
in the rejection of claim 2 (a corresponding method claim). 

In regard to claim 15, incorporating the rejection of claim 14: 

Claim 15 (a computer program product claim) is rejected for the same reasons put forth 
in the rejection of claim 3 (a corresponding method claim). 

In regard to claim 16, incorporating the rejection of claim 15: 

Claim 16 (a computer program product claim) is rejected for the same reasons put forth 
in the rejection of claim 4 (a corresponding method claim). 

In regard to claim 17, incorporating the rejection of claim 13: 

Claim 17 (a computer program product claim) is rejected for the same reasons put forth 
in the rejection of claim 5 (a corresponding method claim). 
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In regard to claim 18, incorporating the rejection of claim 17: 
Claim 18 (a computer program product claim) is rejected for the same reasons put forth 
in the rejection of claim 6 (a corresponding method claim). 

In regard to claim 19: 

"a server explorer module for presenting one or more processing resources present on a 
server to a programmer for use in creating a programming object class; See the Fowlow 
Abstract, Figure 5, and column 1 1, lines 22 - 35). 

"a visual design surface module for performing the operations associated with creating, 
editing, and saving the programming object, the visual design surface module comprises: 

a drag/drop module for enabling a programmer to select a server resource from 
the server explorer module and place the selected server resource within a data object on 
the visual design surface module, Fowlow discloses a drag and drop function wherein a 
component representing software resources on a distributed object system (column 9, 
lines 45 - 47) is selected and dragged from one panel and dropped onto another panel 
being a worksheet (visual design surface) where the object component is manipulated in 
an application construction (column 11, lines 29 - 46). 

a command adapter function generation module for generating a data processing 
object associated with the drag and drop of a server processing resource, The Fowlow 
invention generates code corresponding to the connection (resource) in the design surface 
(column 11, lines 37 - 63). 
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a typed dataset generation module for generating typed dataset object associated 
with the drag and drop of a server processing resource, Fowlow discloses a drag and 
drop function that allows a user to configure objects in a visual design surface giving the 
developer detailed information about the objects, but does not disclose a dataset 
containing data structures corresponding to the resource schema. However, Goldberg 
discloses generation of query objects based on a schema on an underlying database 
(column 2, lines 15-31; column 3, lines 13-19). Therefore, it would have been 
obvious to one skilled in the art at the time the invention was made to combine the drag 
and drop function allowing a user to configure objects in a visual design surface giving 
the developer detailed information about the objects in the Fowlow invention with the 
generation of query objects based on a schema on an underlying database in the Goldberg 
invention because the Fowlow invention discloses that detailed information about an 
object resource is available to the developer (column 9, lines 54 - 55) in the worksheet (a 
visual design surface), and one skilled in the art would logically include a data schema if 
a database resource was selected in a tiered distributed object system as taught by 
Goldberg (Abstract; column 2, lines 17 - 37). 

an init generation module for generating the set of data processing functions and 
methods associated with the drag and drop of a server processing resource, The Fowlow 
invention generates code corresponding to the connection (resource) in the design surface 
(column 11, lines 37 - 63). 
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a properties edit module for retrieving the properties and source code for the 
various objects within the visual design surface module for editing. " See Fowlow 
column 4, lines 18 -26 teaching a composition workspace for editing. 
In regard to claim 20, incorporating the rejection of claim 19: 

. .the drag and drop module comprises: 
an explorer interface module to select a server resource from the server explorer module 
and place it within a data object within the visual design surface module, Fowlow discloses the 
selection of a component from one module and placing it on a visual design surface into a part 
representing an object (Abstract, Figure 5). 

a user interface module to perform the visual display and command input operations 
associated with the drag/drop operation, In the Fowlow invention, the user interfaces with the 
visual display including inputs associated with the drag and drop operation (Figure 5, column 11, 
lines 27 -46). 

a class generation module to cause the visual design surface module to perform the 
operations to complete the drag/drop process of a server resource onto the visual design surface 
module. " See Fowlow column 1 1, lines 1-28. 

In regard to claim 21, incorporating the rejection of claim 19: 

"..the drag/drop module further causes the other processing modules in the visual design 
surface module 402 to perform their operations to complete the drag/drop process of a server 
resource onto the visual design surface module. " See Fowlow column 1 1, lines 29 - 56. 

In regard to claim 22, incorporating the rejection of claim 19: 

"...the command adapter function generation module comprises: 
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a GetDS module for generating a GetDataSet function that fills a typed dataset with data 
obtained from a corresponding database; 

an updateDS module for generating an UpdateDataSet function that updates a 
database using the data stored within the typed dataset " Fowlow does dot teach database 
access functions, but Goldberg teaches a query object with database query commands (column 2, 
lines 38 - 43), including select (getDS) and update (updateDSs). Therefore, it would have been 
obvious to one skilled in the art at the time the invention was made to combine the drag and drop 
function allowing a user to configure objects in a visual design surface giving the developer 
detailed information about the objects in the Fowlow invention with the generation of query 
objects based on a schema of an underlying database in the Goldberg invention, because the 
Fowlow invention discloses that detailed information about an object resource is available to the 
developer (column 9, lines 54-55) in the worksheet (a visual design surface), and one skilled in 
the art would logically include a data schema and database queries if a database resource was 
selected in a tiered distributed object system as taught by Goldberg (Abstract; column 2, lines 17 
-37). 

In regard to claim 23, incorporating the rejection of claim 19: 

"... the command adapter Junction generation module further accepts an updated 
command adapter module that has been edited by the properties edit module and generates the 
updated source code for the Junctions within the command adapter modules. " See Fowlow 
column 11, lines 29 - 56. 

In regard to claim 24, incorporating the rejection of claim 19: 

"... the typed dataset generation module comprises: 
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a Table Schema module for generating the table records from the database schema 
within the dataset object; and 

a Relations module for generating the relationship data for the fields within the records 
within the dataset based upon the corresponding relationship data from the database', Fowlow 
discloses a drag and drop function that allows a user to configure objects in a visual design 
surface giving the developer detailed information about the objects, but does not disclose a 
dataset containing data structures corresponding to the resource schema or relations for the fields 
within the dataset. However, Goldberg discloses generation of query objects based on a schema 
on an underlying database (Abstract; column 2, lines 17-37) generation of relationship data for 
the fields (column 3, lines 40 - 45). Therefore, it would have been obvious to one skilled in the 
art at the time the invention was made to combine the drag and drop function allowing a user to 
configure objects in a visual design surface giving the developer detailed information about the 
objects in the Fowlow invention with the generation of query objects based on a schema of an 
underlying database in the Goldberg invention because the Fowlow invention discloses that 
detailed information about an object component available to the developer (column 9, lines 54 - 
55) in the worksheet (a visual design surface), and one skilled in the art would logically include a 
data schema if a database resource was selected in a tiered distributed object system as taught by 
Goldberg (Abstract; column 2, lines 17-37). 

a Views module for generating the database views data for the records within the dataset 
based upon the corresponding views data from the database. " Fowlow does not disclose a view 
of database records, but Goldberg discloses a view of database records in constructing an SQL 
query (column 37, lines 51-65; Figure 8). Therefore, it would have been obvious to one skilled 



Application/Control Number: 09/734,072 Page 14 

Art Unit: 2124 

in the art at the time the invention was made to combine the drag and drop function allowing a 
user to configure objects in a visual design surface giving the developer detailed information 
about the objects in the Fowlow invention, with the generation of query objects based on a 
schema on an underlying database in the Goldberg invention in order to create views of the 
database, because the Fowlow invention discloses that detailed information about a resource is 
available to the developer (column 9, lines 54-55) in the worksheet (a visual design surface), 
and one skilled in the art would logically include a data schema to construct views for queries if 
a database resource was selected in a tiered distributed object system as taught by Goldberg 
(Abstract; column 2, lines 17 - 37). 

In regard to claim 25, incorporating the rejection of claim 19: 

"... the typed dataset generation module further accepts an updated typed dataset module 
that has been edited by the properties edit module and generates the updated source code for the 
functions within the typed dataset module. " Fowlow generates code for the application software 
under construction (Abstract), but does not accept an updated typed dataset module. However, 
Goldberg discloses query objects that encapsulate a specific query language and the database 
organization or schema, including typing. Therefore, it would have been obvious to one skilled 
in the art at the time the invention was made to combine the drag and drop function allowing 
code generation for the application software under construction in the Fowlow invention, with 
the generation of query objects based on a schema on an underlying database in the Goldberg 
invention in order to create views of the database with a query language, because the Fowlow 
invention discloses that detailed information about a resource is available to the developer 
(column 9, lines 54-55) in the worksheet (a visual design surface), and one skilled in the art 



Application/Control Number: 09/734,072 Page 1 5 

Art Unit: 2124 

would logically include a data schema to construct queries if a database resource was selected in 
a tiered distributed object system as taught by Goldberg (Abstract; column 2, lines 17-37). 

In regard to claim 26, incorporating the rejection of claim 19: 

"...the init generation module comprises: 

an Init Function module for generating the processing functions and methods within the 
programmable data object associated with the command adapter modules; 

an InitDataSet module for generating the processing functions and methods within a 
programmable data object module associated with the type dataset class; 

an InitConnection module for generating the processing functions and methods within the 
programmable data object associated with the data transfer connection between the 
programmable data object and the database. " 

The Fowlow invention generates code corresponding to the connection (resource) in the 
design surface (column 1 1, lines 37 - 63) but does not teach using a data set. However, the 
Goldberg invention generates queries in a specific query language (column 2, lines 17 - 64). In 
order to develop a query it would be inherently necessary to initialize a function (a query object) 
and the dataset and establish a connection to the database. Therefore, it would have been 
obvious to one skilled in the art at the time the invention was made to combine the drag and drop 
function allowing code generation for the application software under construction in the Fowlow 
invention, with the generation of query objects based on a schema on an underlying database in 
the Goldberg invention in order to create views of the database with a query language, because 
the Fowlow invention discloses that detailed information about a selected object component 
available to the developer (column 9, lines 54 - 55) in the worksheet (a visual design surface), 
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and one skilled in the art would logically include a data schema to construct queries if a database 
resource was selected in a tiered distributed object system as taught by Goldberg (Abstract; 
column 2, lines 17 - 37). 

In regard to claim 27, incorporating the rejection of claim 19: 

"... the init generation module further accepts an updated Code Generated Method 
module that has been edited by the properties edit module and generates the updated source 
code for the functions within the command adapter modules, " Fowlow discloses an editing 
module available to update code for the interface functions (column 13, lines 17 - 30). 

In regard to claim 28, incorporating the rejection of claim 19: 

" .. the properties edit module comprises: 

a Properties Retrieval module for retrieving the properties and source code for 

the various objects within the visual design surface module 402 for editing; Fowlow 

teaches that properties and code are retrieved within the visual design surface for editing 

(column 13, lines 17 - 30). 

a User Interface module for presenting the properties and source code to a 

programmer, and accepting edits from the programmer; See Fowlow column 13, lines 

17-30. 

a class update module for updating the edited object " See Fowlow (column 13, 
lines 12 - 30). 

In regard to claim 29, incorporating the rejection of claim 19: 
" ..the class update module further: 
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identifies all other items within the visual design surface module that are affected by the 
changes made to the edited item; 

updates the identified items consistent with the edits made to the edited item. " 

See Fowlow wherein all items affected by an update are identified and updated (column 
11, lines 1-63). 

In regard to claim 30, incorporating the rejection of claim 19: 

"...the properties edit module further: 

identifies all other objects within the visual design surface module 402 that are affected 
by the changes made by the update operations; 
updates the identified objects. " 

See Fowlow wherein all objects affected by an update are identified and updated (column 
11, lines 1-63). 



Conclusion 

4. The prior art made of record and not relied upon is considered pertinent to 
applicant's disclosure: 

U.S. Patent 5,742,284 to Duggan et al., regarding dragging and dropping objects between 
windows. 

U.S. Patent 6,005,576 to Kojima et al., regarding visual programming. 

U.S. Patent 6,199,199 to Johnston et al., regarding presentation of visual programming. 




Application/Control Number: 09/734,072 



Page 18 



Art Unit: 2124 

U.S. Patent 6,243,737 to Flanagan et al., regarding mapping of client and host 
transactions. 



examiner should be directed to Lawrence Shrader whose telephone number is (703) 305-8046. 
The examiner can normally be reached on M-F 08:00-16:30. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Kakali Chaki can be reached on (703) 305-9662. The fax phone number for the 
organization where this application or proceeding is assigned is (703) 746-7239. 

Any inquiry of a general nature or relating to the status of this application or proceeding 
should be directed to the receptionist whose telephone number is (703) 305-3900. 

Lawrence Shrader 

Examiner 

Art Unit 2124 

12 December 2003 A 
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